import java.util.ArrayList;

public class Main {

    public static void main(String[] args) {
        System.out.println("Pride and Prejudice");

        ArrayList<String> words = new ArrayList<>();
        if (FileOperation.readFile("pride-and-prejudice.txt", words)) {

            // Test BST
            long startTime = System.currentTimeMillis();

            BST<String, Integer> bst = new BST<>();
            for (String word : words) {
                if (bst.contains(word)) {
                    bst.set(word, bst.get(word) + 1);
                } else {
                    bst.add(word, 1);
                }
            }

            for (String word : words) {
                bst.contains(word);
            }

            long endTime = System.currentTimeMillis();
            double time = (endTime - startTime) / 1000.0;
            System.out.println("BST: " + time + "s");

            // Test AVL Tree
            startTime = System.currentTimeMillis();

            AVLTree<String, Integer> avl = new AVLTree<>();
            for (String word : words) {
                if (avl.contains(word)) {
                    avl.set(word, avl.get(word) + 1);
                } else {
                    avl.add(word, 1);
                }
            }

            for (String word : words) {
                avl.contains(word);
            }

            endTime = System.currentTimeMillis();
            time = (endTime - startTime) / 1000.0;
            System.out.println("AVL: " + time + "s");
        }
    }

}
